package io.xccit.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import java.io.Serializable;
import java.util.Collection;
import java.util.Date;
import java.util.List;

import lombok.Data;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.userdetails.UserDetails;

/**
 * 用户表
 * @TableName sys_user
 */
@TableName(value ="sys_user")
@Data
public class SysUser implements Serializable,UserDetails {
    /**
     * 用户主键
     */
    @TableId(type = IdType.AUTO)
    private Long id;

    /**
     * 登录用户名
     */
    private String username;

    /**
     * 密码
     */
    private String password;

    /**
     * 真实姓名
     */
    private String realName;

    /**
     * 昵称
     */
    private String nickName;

    /**
     * 所属部门ID
     */
    private Long deptId;

    /**
     * 所属部门名称
     */
    private String deptName;

    /**
     * 性别(0女 1男)
     */
    private Integer gender;

    /**
     * 手机号
     */
    private String phone;

    /**
     * 邮箱
     */
    private String email;

    /**
     * 用户头像
     */
    private String avatar;

    /**
     * 是否管理员(0否 1是)
     */
    private Integer isAdmin;

    /**
     * 账号是否开启(-1开启 0未开启)
     */
    private boolean isEnabled;

    /**
     * 账号是否过期(-1未过期 0已过期)
     */
    private boolean isAccountNonExpired;

    /**
     * 账号是否锁定(-1未锁定 0已锁定)
     */
    private boolean isAccountNonLocked;

    /**
     * 密码是否过期(-1未过期 0已过期)
     */
    private boolean isCredentialsNonExpired;

    /**
     * 创建时间
     */
    private Date createTime;

    /**
     * 更新时间
     */
    private Date updateTime;

    /**
     * 是否删除(0否 1是)
     */
    private Integer isDelete;

    /**
     * 简介
     */
    private String remark;

    /**
     * 用户权限(Spring Security强制实现)
     */
    @TableField(exist = false)
    private Collection<? extends GrantedAuthority> authorities;

    /**
     * 用户角色
     */
    @TableField(exist = false)
    private List<SysRole> roles;

    /**
     * 用户权限
     */
    @TableField(exist = false)
    private List<SysPermission> permissions;
    @TableField(exist = false)
    private static final long serialVersionUID = 1L;
}